<!-- subpkg_archive/list/index.vue -->
<script lang="ts" setup>
import { patientListApi, removePatientApi } from '@/apis/patient'
import type { PatientItem } from '@/types/patient'
import { onShow } from '@dcloudio/uni-app'
import { ref } from 'vue'

  const swipeOptions = ref([
    {
      text: '删除',
      style: {
        backgroundColor: '#dd524d',
        color: '',
        fontSize: '',
      },
    },
  ])

// 1. 获取患者列表数据
const patinetList = ref<PatientItem[]>([])
// 家庭档案（患者）列表
async function getPatientList() {
  // 患者列表接口
  const data = await patientListApi()
  // 渲染接口数据
  patinetList.value = data
}
onShow(() => {
  getPatientList()
})

// 2. 滑动操作点击
const onSwipeActionClick = async (id: string, index: number) => {
  console.log('3232');
  // 调用删除患者接口
  await removePatientApi(id)
  // Vue 实例中的数据也要同步删除
  patinetList.value.splice(index, 1)
}
</script>

<template>
  <scroll-page>
    <view class="archive-page">
      <view class="archive-tips">最多可添加6人</view>
      <uni-swipe-action>
        <uni-swipe-action-item :right-options="swipeOptions" v-for="(item, index) in patinetList" :key="item.id"
          @click="onSwipeActionClick(item.id, index)">
          <view class="archive-card" :class="{ active: item.defaultFlag === 1 }">
            <view class="archive-info">
              <text class="name">{{item.name}}</text>
              <text class="id-card">{{ item.idCard }}</text>
              <text class="default" v-if="item.defaultFlag === 1">默认</text>
            </view>
            <view class="archive-info">
              <text class="gender">{{ item.genderValue }}</text>
              <text class="age">{{item.age}}岁</text>
            </view>
            <navigator hover-class="none" class="edit-link" :url="`/subpkg_archive/form/index?id=${item.id}`">
              <uni-icons type="icon-edit" size="20" color="#16C2A3" custom-prefix="iconfont" />
            </navigator>
          </view>
        </uni-swipe-action-item>
      </uni-swipe-action>

      <!-- 添加按钮 -->
      <view v-if="patinetList.length < 6" class="archive-card">
        <navigator class="add-link" hover-class="none" url="/subpkg_archive/form/index">
          <uni-icons color="#16C2A3" size="24" type="plusempty" />
          <text class="label">添加患者</text>
        </navigator>
      </view>
    </view>
  </scroll-page>
</template>

<style lang="scss">
  @import './index.scss';
</style>